草庐IT

java - 在 Java 中模拟 URL

全部标签

java - 如何使用 gorm 动态添加查询参数?

我是golang开发的新手。我有6个参数要使用gorm传递给查询。这是选择查询,因此,我们需要根据输入值过滤值。因此,我们需要将过滤器动态传递到查询中。我试过了,但没有解决方案。funcGetUsers(DB*gorm.DB,Offsetint,Limitint,Useruibackendmodels.UserDetails)(Users[]uibackendmodels.UserDetails,Err错误){query:="SELECTuserid,username,nickname,email,mobile,location,status,roleids,trsids,brandi

mongodb - 在 Go 中模拟 MongoDB 响应

我正在从MongoDB获取文档并将其传递给函数transform,例如vardocmap[string]interface{}err:=collection.FindOne(context.TODO(),filter).Decode(&doc)result:=transform(doc)我想为transform编写单元测试,但我不确定如何模拟来自MongoDB的响应。理想情况下,我想设置这样的东西:funcTestTransform(t*testing.T){byt:=[]byte(`{"hello":"world","message":"apple"}`)vardocmap[stri

go - 使用 go-mocket 模拟 GORM 数据库不起作用

我正在尝试使用go-mocket来模拟gorm数据库,但它无法正常工作。我没有向我的ClusterExists函数发送任何模拟数据,因此单元测试无法按预期工作。在文档中有两种模拟“简单链用法”和“FakeResponse”的方法。我已经尝试了两种方法,但都不起作用。我的功能:funcClusterExists(cluster*Cluster,db*gorm.DB)bool{c:=Cluster{}exists:=!db.Where("cluster_name=?ANDenv_type=?",cluster.ClusterName,cluster.EnvType).First(&c).R

java - 带有数据流的 Apache Beam Go SDK

我一直在使用GoBeamSDK(v2.13.0),但无法获得wordcountexample致力于GCP数据流。它进入崩溃循环以尝试启动org.apache.beam.runners.dataflow.worker.DataflowRunnerHarness。该示例在使用Directrunner在本地运行时正确执行。该示例与上面给出的原始示例完全没有修改。堆栈跟踪是:org.apache.beam.vendor.grpc.v1p13p1.com.google.protobuf.InvalidProtocolBufferException:Protocolmessagehadinvali

go - 将换行符添加到 base64url 字符串

我有一个发送base64url编码字符串的程序,但我在某些地方读到base64不支持'\'字符。我的目的是用GmailAPI发送电子邮件在去。正文部分由以下部分组成:"Name:\n\nThisisthebodyoftheemail\n\nSincerely,\nSenderName"当我sendemailsthroughtheGmailAPI,我需要向它传递一个base64url字符串。我有以下功能来处理:funcencodeWeb64String(b[]byte)string{s:=base64.URLEncoding.EncodeToString(b)vari=len(s)-1f

http - 如何在请求中转义正斜杠以使 url-routers 将其计为 uri 参数的一部分?

我使用gorilla/mux进行路由映射:router.Handle("/v1/data/{param}",handler)当我调用curlhttp://localhost:8080/v1/data/hello%2Fworld时,我得到了404响应代码。问题是,在我的微服务中,我想将/v1/data/之后的所有内容解释为param。捕获参数的代码如下:uriP:=mux.Vars(r)param:=uriP["param"]是否可以使用gorilla/mux实现此目的?或任何其他路由器? 最佳答案 您应该添加正则表达式,因为默认的正

google-app-engine - 具有运行时 go111 url 调度问题的 dev_appserver.py

我仍在努力让我的旧式应用引擎至少在go111下工作(由于依赖于内存缓存,go112将无法工作)。我现在正在为我的静态文件的app.yaml配置问题绊倒,我之前使用了一个完全静态的目录布局,只是在根目录中指定了一些动态处理程序,如下所示:runtime:go111handlers:-url:/_ah/.*script:autologin:adminsecure:always-url:/dynamicscript:autosecure:always-url:/admin/.*script:autologin:adminsecure:always-url:(.*)/static_files:

go - 模拟外部库以进行单元测试

我有一个下面的函数tryGet()来进行单元测试:typeconfigstruct{Keystring`json:"key"`Clienttodo.Client`json:"client"`}varinstance*configfunc(c*config)tryGet()error{client:=&http.Client{}tClient:=Client{"http://url",client}configValues:=config{"Key",tClient}Instance:=&configValueserr:=Instance.Client.perform("GET",hea

unit-testing - 如何为另一个包中的方法编写模拟代码

我正在为service.go设置service_test.go。在service.go中,方法是从dao.go中调用的。所以我需要模拟这个dao方法。但我不确定如何编写此模拟方法的代码。这是存储库结构。article├client├api│├main.go│├contoroller││└contoroller.go│├service││└service.go│├dao││└dao.go│├go.mod│├go.sum│└Dockerfile├nginx└docker-compose.yml服务.gofuncGetArticleService(db*sql.DB)[]util.Artic

networking - 以编程方式模拟数据包丢失和延迟

我有一个通过rpc公开其服务的服务器和一个使用这些服务的客户端。为了测试此设置,我需要引入数据包丢失和延迟。我在stackoverflow上发现了一些技术,如tc、修改iptables等,但它们都需要root密码来模拟丢包。有没有一种方法可以在不需要root密码的情况下模拟这些数据包丢失。注意:代码是用GO编程语言编写的 最佳答案 一种方法是隔离您的数据包处理代码,并创建它的模拟版本(或ifdef'd部分),用于测试,以您选择的方式行为不当。这可能足以满足您的需求。对于商业或关键应用程序的工业强度测试,您至少需要一个有root密码的